package com.sheng.leetcode.year2023.month10.day15;

import org.junit.Test;

/**
 * @author by ls
 * @date 2023/10/16
 * <p>
 * 137. 只出现一次的数字 II<p>
 * <p>
 * 给你一个整数数组 nums ，除某个元素仅出现 一次 外，其余每个元素都恰出现 三次 。请你找出并返回那个只出现了一次的元素。<p>
 * 你必须设计并实现线性时间复杂度的算法且使用常数级空间来解决此问题。<p>
 * <p>
 * 示例 1：<p>
 * 输入：nums = [2,2,3,2]<p>
 * 输出：3<p>
 * <p>
 * 示例 2：<p>
 * 输入：nums = [0,1,0,1,0,1,99]<p>
 * 输出：99<p>
 * <p>
 * 提示：<p>
 * 1 <= nums.length <= 3 * 10^4<p>
 * -2^31 <= nums[i] <= 2^31 - 1<p>
 * nums 中，除某个元素仅出现 一次 外，其余每个元素都恰出现 三次<p>
 */
public class LeetCode0137 {

    @Test
    public void test01() {
//        int[] nums = {2, 2, 3, 2};
        int[] nums = {0, 1, 0, 1, 0, 1, 99};
        System.out.println(new Solution().singleNumber(nums));
    }
}

class Solution {
    public int singleNumber(int[] nums) {
        int[] ints = new int[32];
        for (int num : nums) {
            for (int i = 0; i < 32; i++) {
                if (((num >> i) & 1) == 1) {
                    ints[i]++;
                }
            }
        }
        int ans = 0;
        for (int i = 0; i < 32; i++) {
            if ((ints[i] % 3 & 1) == 1) {
                ans += (1 << i);
            }
        }
        return ans;
    }
}
